#
#  $Id$
#

@SET_MAKE@
srcdir = @srcdir@
VPATH = @srcdir@
RTEMS_ROOT = @top_srcdir@
PROJECT_ROOT = @PROJECT_ROOT@

RELS=$(ARCH)/rtems-cpu.rel

# C source names, if any, go here -- minus the .c
#  Normally cpu_asm and rtems are assembly files
C_PIECES=cpu
C_FILES=$(C_PIECES:%=%.c)
C_O_FILES=$(C_PIECES:%=${ARCH}/%.o)

H_FILES=$(srcdir)/cpu.h $(srcdir)/ppc.h $(srcdir)/ppctypes.h

# H_FILES that get installed externally
EXTERNAL_H_FILES = $(srcdir)/asm.h

# Assembly source names, if any, go here -- minus the .s
#  Normally cpu_asm and rtems are assembly files
S_PIECES=cpu_asm rtems
S_FILES=$(S_PIECES:%=%.s)
S_O_FILES=$(S_FILES:%.s=${ARCH}/%.o)

SRCS=$(C_FILES) $(CC_FILES) $(H_FILES) $(S_FILES) $(EXTERNAL_H_FILES) 
OBJS=$(C_O_FILES) $(CC_O_FILES) $(S_O_FILES)

include $(RTEMS_ROOT)/make/custom/$(RTEMS_BSP).cfg
include $(RTEMS_ROOT)/make/leaf.cfg

#
# (OPTIONAL) Add local stuff here using +=
#

DEFINES  +=
CPPFLAGS +=
CFLAGS   += $(CFLAGS_OS_V)

LD_PATHS  +=
LD_LIBS   +=
LDFLAGS   +=

#
# Add your list of files to delete here.  The config files
#  already know how to delete some stuff, so you may want
#  to just run 'make clean' first to see what gets missed.
#  'make clobber' already includes 'make clean'
#

CLEAN_ADDITIONS +=
CLOBBER_ADDITIONS +=

all:	${ARCH} $(SRCS) preinstall $(OBJS) $(RELS)

$(ARCH)/rtems-cpu.rel: $(OBJS)
	$(make-rel)

$(ARCH)/cpu_asm.o: irq_stub.s

# Install the program(s), appending _g or _p as appropriate.
# for include files, just use $(INSTALL)
install:  all

preinstall: $(ARCH) \
            $(PROJECT_INCLUDE)/rtems/score/targopts.h \
            ${PROJECT_RELEASE}/lib/bsp_specs
	$(INSTALL) -m 444 ${H_FILES} $(PROJECT_INCLUDE)/rtems/score
# we will share the basic cpu file
	$(INSTALL) -m 444 ${EXTERNAL_H_FILES} $(PROJECT_INCLUDE)
# make a link in case we are not compiling in the source directory
	test -f irq_stub.s || $(LN) -s $(srcdir)/irq_stub.s irq_stub.s

$(PROJECT_INCLUDE)/rtems/score/targopts.h: $(ARCH)/targopts.h-tmp
	$(INSTALL) -m 444 $(ARCH)/targopts.h-tmp $@

# $(ARCH)/targopts.h-tmp rule is in leaf.cfg

${PROJECT_RELEASE}/lib/bsp_specs: $(ARCH)/bsp_specs.tmp
	$(INSTALL) -m 444 $(ARCH)/bsp_specs.tmp $@

# $(ARCH)/bsp_specs.tmp rule is in leaf.cfg
